@mixin horizontal-menu {
    .foxui-menu-menu {
        @include popper-panel;
        min-width: $--menu-menu-min-width;

        .foxui-menu-item {
            cursor: pointer;
            padding: 0 $--menu-padding;
            line-height: $--meun-item-horizontal-height;
            height: $--meun-item-horizontal-height;
            transition: $--all-transition;

            &:hover {
                background-color: $--color-primary-light-9;
            }

            &.foxui-menu-child {
                transition: $--all-transition;

                .foxui-menu-icon {
                    &::after {
                        transform: rotate(-90deg);
                        position: absolute;
                        right: $--menu-padding;
                    }

                    &.is-active {
                        &::after {
                            transform: rotate(90deg);
                        }
                    }
                }
            }

            &:not(.foxui-menu-child) {
                transition: $--all-transition;

                &:hover {
                    color: $--color-primary-light-1;
                }

                &.is-active {
                    color: $--color-primary;
                }
            }

            a {
                display: inline-block;
                width: 100%;
                height: 100%;
                transition: $--all-transition;

                &:hover {
                    color: $--color-primary;
                }
            }

            &.is-active {
                a {
                    color: $--color-primary;
                }
            }
        }

        .foxui-menu-handle {
            line-height: $--meun-item-horizontal-height;
            height: $--meun-item-horizontal-height;
        }
    }

    .foxui-menu-slide {
        margin: $--menu-margin 0;
        max-height: $--menu-item-height * 6;
        overflow: auto;
    }

    .foxui-menu-item-title {
        padding: 0 $--menu-padding;
    }
}

.foxui-menu {
    display: flex;
    width: 100%;
    transition: width 0.3s;
    position: relative;

    a {
        color: #000;
    }

    .foxui-menu-submenu-icon {
        display: inline-block;
        height: 100%;
        width: 24px;
        text-align: center;
    }

    .foxui-menu-icon {
        &::after {
            content: '\e8ad';
            font-family: 'foxuifont';
            display: inline-block;
            transform: rotate(0deg);
            margin-left: $--padding-extra-small;
            transition: transform 0.3s cubic-bezier(0.645, 0.045, 0.355, 1);
        }

        &.is-active {
            &::after {
                transform: rotate(180deg);
            }
        }
    }

    .foxui-menu-submenu > .foxui-menu-handle,
    & > .foxui-menu-item {
        height: $--menu-handle-height;
        line-height: $--menu-handle-height;
        padding: 0 $--menu-padding;
        transition: $--all-transition;
        cursor: pointer;
    }

    .foxui-menu-handle,
    .foxui-menu-menu .foxui-menu-item:not(.foxui-menu-child) {
        height: $--menu-item-height;
        line-height: $--menu-item-height;
    }

    .foxui-menu-handle,
    .foxui-menu-submenu,
    .foxui-menu-item {
        white-space: nowrap;
    }

    .foxui-menu-item-title {
        height: $--menu-item-title-height;
        line-height: $--menu-item-title-height;
        color: $--color-text-secondary;
        font-size: $--menu-item-title-font-size;
    }

    // 横向导航
    &:not(.foxui-type-vertical) {
        flex-direction: row;

        .foxui-menu-submenu > .foxui-menu-handle,
        & > .foxui-menu-item {
            transition: $--all-transition;

            &:hover {
                color: $--color-primary;
            }
        }

        .foxui-menu-submenu {
            > .foxui-menu-menu {
                margin-top: 6px;
            }
        }

        // menu
        @include horizontal-menu();
    }

    // 纵向导航
    &.foxui-type-vertical {
        flex-direction: column;

        .foxui-menu-submenu .foxui-menu-handle,
        & > .foxui-menu-item {
            transition: $--all-transition;

            &:hover {
                background-color: $--color-primary-light-9;
            }
        }

        .foxui-menu-handle {
            span {
                display: inline-block;
                width: calc(100% - 50px);
            }
        }

        // menu
        .foxui-menu-menu {
            display: none;

            // 各层 padddin
            .foxui-menu-item:not(.foxui-menu-child),
            .foxui-menu-item-title {
                padding-left: $--menu-padding * 2;
                background-color: rgba($--color-primary-light-9, 0.4);
            }

            .foxui-menu-handle {
                padding-left: $--menu-padding;
            }

            .foxui-menu-item.foxui-menu-child {
                .foxui-menu-item:not(.foxui-menu-child),
                .foxui-menu-item-title {
                    padding-left: $--menu-padding * 3;
                }

                .foxui-menu-handle {
                    padding-left: $--menu-padding * 2;
                }

                .foxui-menu-item.foxui-menu-child {
                    .foxui-menu-item:not(.foxui-menu-child),
                    .foxui-menu-item-title {
                        padding-left: $--menu-padding * 4;
                    }

                    .foxui-menu-handle {
                        padding-left: $--menu-padding * 3;
                    }

                    .foxui-menu-item.foxui-menu-child {
                        .foxui-menu-item:not(.foxui-menu-child),
                        .foxui-menu-item-title {
                            padding-left: $--menu-padding * 5;
                        }

                        .foxui-menu-handle {
                            padding-left: $--menu-padding * 4;
                        }
                    }
                }
            }
        }

        // item
        .foxui-menu-item {
            cursor: pointer;

            &:not(.foxui-menu-child) {
                &.is-active {
                    background-color: $--color-primary-light-8;
                    color: $--color-primary;
                    border-right: $--color-primary solid 2px;

                    a {
                        color: $--color-primary;
                    }
                }

                &:not(.is-active) {
                    transition: $--all-transition;

                    &:hover {
                        color: $--color-primary;
                    }
                }

                &:not(.is-active) {
                    a {
                        display: inline-block;
                        width: 100%;
                        height: 100%;
                        transition: $--all-transition;

                        &:hover {
                            color: $--color-primary;
                        }
                    }
                }
            }
        }

        // 纵向折叠导航
        &.is-collapse {
            display: inline-block;
            width: $--menu-collapse-width;

            > .foxui-menu-submenu {
                > .foxui-menu-handle {
                    &::after {
                        display: none;
                    }

                    span {
                        display: none;
                    }
                }
            }

            > .foxui-menu-item {
                span {
                    display: none;
                }
            }

            .foxui-menu-item:not(.foxui-menu-child),
            .foxui-menu-item-title {
                padding-left: $--menu-padding !important;
            }

            .foxui-menu-menu {
                .foxui-menu-item {
                    .foxui-menu-handle {
                        padding-left: 0 !important;
                    }
                }
            }

            .foxui-menu-item:not(.foxui-menu-child):not(.is-active),
            .foxui-menu-item-title {
                background-color: transparent;
            }

            // menu
            @include horizontal-menu();
        }
    }

    // 黑暗模式
    &.is-dark {
        background-color: $--menu-dark-background-color;
        color: #fff;

        .foxui-menu-menu {
            background-color: $--menu-dark-background-color;
            border: none;

            .foxui-menu-item {
                a {
                    color: #fff;
                }

                &.is-active {
                    a {
                        color: #fff;
                    }
                }
            }
        }

        &.foxui-type-vertical {
            & > .foxui-menu-submenu .foxui-menu-handle,
            .foxui-menu-item {
                transition: $--all-transition;

                &:hover {
                    background-color: $--menu-dark-hover-background-color;
                    color: #fff;
                }
            }

            .foxui-menu-menu {
                .foxui-menu-item:not(.foxui-menu-child),
                .foxui-menu-item-title {
                    background-color: $--menu-dark-child-background-color;
                }
            }

            .foxui-menu-item:not(.foxui-menu-child) {
                &.is-active {
                    background-color: $--color-primary;
                    color: #fff;
                }
            }

            &.is-collapse {
                .foxui-menu-menu {
                    border: none;
                    background-color: $--menu-dark-child-background-color;
                }

                .foxui-menu-item:not(.foxui-menu-child) {
                    &.is-active {
                        color: #fff;
                    }
                }

                .foxui-menu-item {
                    &.is-active {
                        a {
                            color: #fff;
                        }
                    }
                }

                .foxui-menu-child {
                    background-color: $--menu-dark-child-background-color;

                    &:hover {
                        background-color: $--menu-dark-hover-background-color;
                    }
                }
            }
        }

        &:not(.foxui-type-vertical) {
            .foxui-menu-menu {
                .foxui-menu-item {
                    transition: $--all-transition;

                    &:hover {
                        background-color: $--menu-dark-hover-background-color;
                    }

                    .is-active {
                        a {
                            color: $--color-primary;
                        }
                    }
                }
            }

            .foxui-menu-item:not(.foxui-menu-child) {
                &.is-active {
                    color: $--color-primary;
                }
            }
        }
    }
}
